草庐IT

c++ - 负 ASCII 值

全部标签

c - Ruby C 扩展 API 问题

所以,最近我不幸地需要为Ruby做一个C扩展(因为性能)。因为我在理解上有问题VALUE(并且仍然如此),所以我查看了Ruby源代码并发现:typedefunsignedlongVALUE;(LinktoSource,但您会注意到它还有其他一些“方法”,但我认为它本质上是一个long;如果我错了,请纠正我)。因此,在进一步调查时,我发现了一个有趣的blogpost,其中说:"...insomecasestheVALUEobjectcouldBEthedatainsteadofPOINTINGTOthedata."令我困惑的是,当我尝试从Ruby将字符串传递给C并使用RSTRING_PT

c - 在 C 中扩展 ruby​​ - 如何指定函数的默认参数值?

我正在尝试为将生成一个类的ruby​​编写C扩展。我正在研究如何为类定义一些默认参数。例如,如果我在ruby​​中有这个类decleration:classMyClassdefinitialize(name,age=10)@name=name@age=ageendend您可以使用mc=MyClass.new("blah")初始化它,年龄参数将在内部设置。我如何在C中执行此操作?到目前为止我得到了这个,但这迫使进入另一个论点:require"ruby.h"staticVALUEmy_init(VALUEself,VALUEname,VALUEage){rb_iv_set(self,"@n

ruby - 如何从 Ruby 中的字符串中删除所有非 ASCII 字符

我好像是一个很简单也很需要的方法。我需要从字符串中删除所有非ASCII字符。例如©等。请参见以下示例。#coding:utf-8s="Hellothisamixedstring©thatImade."putss.encodingputss.encode输出:UTF-8Hellothisamixedstring┬⌐我做的。当我将其提供给Watir时,它会产生以下错误:不兼容的字符编码:UTF-8和ASCII-8BIT所以我的问题是我想在使用它之前去掉所有非ASCII字符。我将不知道源字符串“s”使用哪种编码。我已经搜索和试验了一段时间。如果我尝试使用putss.encode('ASCI

c - 如何在 Mac OS X 上使用 ulimit 或每个进程为 C 或 Ruby 程序更改堆栈大小?

似乎为C程序或Ruby程序(使用C堆栈)设置堆栈大小的推荐方法是使用ulimit。在Bash外壳中。但是$ulimit-s8192$ulimit-s16384-bash:ulimit:stacksize:cannotmodifylimit:Operationnotpermitted和sudo也没有帮助。有没有办法将其设置为16MB、32MB或64MB?我认为应该有一种方法可以在每次程序调用时设置它,而不是同时设置系统范围的参数?现在8192可能意味着8MB,如果与一个进程可以使用的内存量相比,这是非常小的,有时最多2GB的RAM。(更新注释:ulimit-a可以显示其当前值)。(更新2

ruby - Ruby中字符的ASCII值

如何在Ruby1.9中获取字符的ASCII值?我在Internet上广泛搜索,但没有成功。我尝试了?x和“x”[0],但它们返回的都是“x”。 最佳答案 String#ord方法可以解决问题:ruby-1.9.2-p136>'x'.ord=>120ruby-1.9.2-p136>'0'.ord=>48ruby-1.9.2-p136>''.ord=>32 关于ruby-Ruby中字符的ASCII值,我们在StackOverflow上找到一个类似的问题: http

ruby-on-rails - rake 任务因 US-ASCII 中的无效字节序列而失败

升级到ruby​​1.9.3后,我的一个应用程序运行良好,但当我尝试使用capistrano进行部署时,我尝试转换的第二个应用程序在“assets:precompile”阶段失败。这是堆栈跟踪:rakeaborted!rakeaborted!invalidbytesequenceinUS-ASCII/Users/george/.rvm/gems/ruby-1.9.3-p392@global/gems/rake-10.0.4/lib/rake/trace_output.rb:16:in`blockintrace_on'/Users/george/.rvm/gems/ruby-1.9.3-

ruby - 转换十六进制、十进制、八进制和 ASCII?

尝试在Ruby中往返...我列出的代码似乎很重复。有更好的方法吗?moduleConverterdefself.convert(value,from,to)casefromwhen:hexcasetowhen:dec#codetochangehextodecwhen:oct#codetochangehextooctwhen:bin#codetochangehextobinwhen:ascii#codetochangehextoasciiendwhen:deccasetowhen:hex#codetochangedectohexwhen:oct#codetochangedectooctw

ruby-on-rails - ruby 正则表达式错误 : incompatible encoding regexp match (ASCII-8BIT regexp with UTF-8 string)

我遇到了两个错误,都与编码有关并且都相关。我在启动WEBrick时遇到的第一个错误(技术上是警告):/Users/USERNAME/example/config/initializers/bb-ruby.rb:54:warning:invalidUnicodeProperty\P:/\:\-?\P/它所指的行是:/\:\-?\P/,这只是一些正则表达式,最终是这个block的一部分:@@tags['Razzing']=[/\:\-?\P/,'','Razzing',':P',:razzing]然后,我在解析一些字符串时也得到了以下错误(大概是由于同一行)...Encoding::Com

ruby - 将具有十六进制 ASCII 代码的字符串转换为字符

我有一个包含ASCII字符的十六进制代码值的字符串,例如“666f6f626172”。我想把它转换成对应的字符串("foobar")。这是有效但丑陋的:"666f6f626172".scan(/../).map(&:hex).map(&:chr).join#=>"foobar"有没有更好(更简洁)的方式?unpack能以某种方式提供帮助吗? 最佳答案 您可以使用Array#pack:["666f6f626172"].pack('H*')#=>"foobar"H是十六进制字符串的指令(高半字节在前)。

Ruby:从字符串到ascii的字符

此wiki页面给出了如何将单个字符转换为ascii的一般概念http://en.wikibooks.org/wiki/Ruby_Programming/ASCII但是假设我有一个字符串并且我想从中获取每个字符的ascii,我需要做什么?"string".each_bytedo|c|$char=c.chr$ascii=?charputs$asciiend它不起作用,因为它对$ascii=?char这行不满意syntaxerror,unexpected'?'$ascii=?char^ 最佳答案 c变量已经包含字符代码!"string".